package it.unipd.dei.bd.icineasti.servlet;

import it.unipd.dei.bd.icineasti.database.GetAllFilmDatabase;
import it.unipd.dei.bd.icineasti.resource.Film;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.Date;
import java.sql.SQLException;
import java.util.List;

import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.sql.DataSource;

/**
 * Servlet per passare il contenuto dell'array con i link alle locandine allo slideshow 
 * e alla corrispondente pagine di scheda dell'evento
 * 
 * @author Morris Antonello
 *
 */
public class SlideshowServlet extends AbstractDatabaseServlet {

	public void doGet(HttpServletRequest req, HttpServletResponse res)
			throws ServletException, IOException {

		// imposta il tipo MIME della risposta
		res.setContentType("text/html");

		// ottiene un flusso di uscita per scrivere la risposta
		PrintWriter out = res.getWriter();

		Connection con = null;
		
		/*["/ICineasti-1.00/image?id=2", "qui ci va un link", "", "qui una stringa che appare in alto nello slideshow"],
		  ["/ICineasti-1.00/image?id=3", "", "", ""],
		  ["/ICineasti-1.00/image?id=4", "", "", ""],
		  ["/ICineasti-1.00/image?id=5", "", "", ""]*/

		try {
			con = DS.getConnection();
			Date dataOra = new Date(System.currentTimeMillis());
			List<Film> film = new GetAllFilmDatabase(con, dataOra).getFilmFromSede();
			
			int i = 0;
			for (Film f : film) {
				out.printf("[\"../image?id=%s\"," + 
							"\"../html/scheda_film.jsp?codiceEvento=%s\", \"\", \"\"]", f.getCodice(), f.getCodice()); 
							// immagine e link alla scheda evento
				i++;
				if (i < film.size()) {
					out.printf(",");
				}
			}

		} catch (NullPointerException e) {
			// messaggio d'errore
			out.printf("<p><center><font color=\"red\" size=\"+2\">Impossibile creare la connessione al database.</font></center></p>");
		} catch (SQLException e) {
			// messaggio d'errore
			out.printf("<p><center><font color=\"red\" size=\"+2\">Errore durante l'accesso al database: %s</font></center></p>",
			e.getMessage());
		}

		// assicura che tutto il contenuto sia inviato
		out.flush();

		// chiude il flusso di uscita
		// out.close();

	}

}
